package com.nidu.demo.tenant.api;

import com.alibaba.cola.dto.MultiResponse;
import com.alibaba.cola.dto.PageResponse;
import com.alibaba.cola.dto.Response;
import com.alibaba.cola.dto.SingleResponse;
import com.nidu.demo.tenant.dto.TenantAddCmd;
import com.nidu.demo.tenant.dto.TenantListQry;
import com.nidu.demo.tenant.dto.TenantPageQry;
import com.nidu.demo.tenant.dto.TenantUpdateCmd;
import com.nidu.demo.common.enums.StatusEnum;
import com.nidu.demo.tenant.dto.*;

import java.util.Set;

/**
 * 租户服务接口
 *
 * @author auto
 */
public interface SysTenantService {

    /**
     * 创建租户
     *
     * @param cmd 租户创建命令
     * @return 创建后的租户信息
     */
    SingleResponse<TenantCO> add(TenantAddCmd cmd);

    /**
     * 更新租户
     *
     * @param cmd 租户更新命令
     * @return 更新后的租户信息
     */
    SingleResponse<TenantCO> update(TenantUpdateCmd cmd);

    /**
     * 删除租户
     *
     * @param id 租户删除命令
     * @return 操作结果
     */
    Response delete(Long id);

    /**
     * 批量删除租户
     * @param ids
     * @return
     */
    Response delete(Set<Long> ids);

    /**
     * 获取租户详情
     *
     * @param id 租户ID
     * @return 租户详情
     */
    SingleResponse<TenantCO> getById(Long id);

    /**
     * 根据租户名称获取详情
     * @param name
     * @return
     */
    SingleResponse<TenantCO> getTenantByName(String name);

    /**
     * 查询租户列表
     *
     * @param qry 查询条件
     * @return 租户列表
     */
    MultiResponse<TenantCO> list(TenantListQry qry);

    /**
     * 分页查询租户
     *
     * @param qry 分页查询条件
     * @return 分页结果
     */
    PageResponse<TenantCO> page(TenantPageQry qry);

    /**
     * 修改状态
     *
     * @param id 租户Id
     * @param statusEnum 状态修改命令
     * @return 操作结果
     */
    Response updateStatus(Long id, StatusEnum statusEnum);
}